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USER INSTRUCTIONS---9400 DIAGNOSTIC 


1.0 GENERAL 


The diagnostic’s basic task is to let the user build up a 
string of commands or tests to be tun, to run the tests, and to 
report the results of these tests. The diagnostic is designed to 
give the user a great deal of flexibility in doing this. With a 
single command, he can run an entire diagnostic, a related group 
of tests, or he can string together tests in any order he choses. 
He can specify how many times each test is to be run before going 
on to the next test, or how many times any combination of tests is 
to be run before going on. He can specify what each test is to do 
in case of error (e.g. pause, loop. or ignore it). He can also 
specify what information will be reported in case of error. 


1.1 BASIC CONVENTIONS: 
1.1.1 Command Levels: 


The diagnostic has two command levels. The normal command 
level is the one in which the user enters commands into the 
command string, responds to initialization queries and requests 
from various tests. The normal command level is indicated by >> 
before each line of output or input. For example: 


>> ENTER NEW CMDS 
>> 


The second command level is the dynamic command level. This 
takes priority over the normal command. The system stops what it 
is doing on the normal command level and begins executing the 
dynamic command. Dynamic command level is indicated by #* before 
each line of output. For example: 


## (CTL E) ERR SPEC (C)=? 
1.1.2 Keyboard Inputs: 


All inputs that the operator makes to the keyboard (except 
dynamic commands) must be followed by <RETURN> for them to be 
- entered. Before <RETURN> is pressed, the operator may delete 
characters one at a time with the <RUBOUT> key. Each time he rubs 
out a character, a CRT terminal will delete the character from the 
screen. However, a TTY terminal will print < until there are no 
more characters to rub out. After several rubouts, the user may 
be confused as to the actual contents of the line. He can review 
the line as it exists after the rubouts by pressing <LINE FEED>. 


-5- 


94DIAG USER ‘’S GUIDE 


When the system prints a question ending with something inside 
a parenthesis, this is either a default value or an existing 
parameter which may be changed. If the operator presses <RETURN> 
without entering anything, the default will be chosen or the 
existing parameter wil] remain unchanged. In other words, by 
entering nothing, the operator has actually entered the value in 
parenthesis. Examples: 


>> STD CPA LOC (Y)* 
>> RPO4 REGS BASE ADDR ('176700)7 = 


In the first example, the default answer is YES. The operator 
must enter "N" to indicate NO. In the second example, the 
existing parameter is 176700 which will remain unchanged if the 
operator enters nothing else. 


If the operator enters something unexpected, such as a negative 
number in the second example above, the system will print ?? and 
repeat the question. 


1.1.3 Number Systems: 


All numbers printed at the console are normally in the decimal 
number system. An octal number will be preceded by an asterisk 
(*), and a hexadecimal number will be preceded by the letter H-. 
Examples: 


256 Decimal 
7000400 Octal 
-H-10C4 Hexadecimal 


The number system shown in the default is the same as that 
assumed in the reply expected from the operator. Example: 


## (CTL P) DATA PATTERNS 
CUR (/125252)? = 


The number entered by the operator is assumed to be octal. 
1.2 INITIALIZATION 
Before the diagnostic can begin testing, it must know what disc 


system is present as well as other details about the system. It 
determines this in a dialog with the operator as follows: 


~&- 
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>> CRT OR TTY (C)? = 


The system needs to know the terminal type in order to supply 
the correct number of fill characters. The default is CRT. If 
using a teletype, the operator should enter "T". 


>> DATE (M-D-Y) 
>> TIME (H: M:S) 


The user may enter date and time exactly as shown in paren- 
thesis. The time is on the 24 hour system with the hours falling 
between O and 23. The user may not wish to enter date and time. 
In this case he simply presses <RETURN> to go on to the next 
question. 


>> STD CPU LOC (Y)? 


If the operator answers YES, the next two questions are skip- 
ped. The system will assume a 9400 interrupt vector address of 
000254, and a 9400 registers base address of 176700. 


>> 9400 INT VECT ADDR (’000254)7 = 
>> 9400 REGS BASE ADDR (/176700)7 = 


The operator may enter the non-standard values in place of the 
standard ones shown in parenthesis. 


If the diagnostic has been loaded from a system disc, this is 
the time to replace the system disc with a scratch pack. 


Next, the system asks the operator to set the format enable 
switch to the ON position, to put the STD/EXT switch to the EXT 
position, and to reset the controller. 


2> SET FMT EN SWITCH ON; PUT STD/EXT SW TO EXT 
>> RST CTLR. HIT <RET> 


It then prints a summary of what drives and drive types are 
present and asks the operator if this is OK. If so, the init- 
ialization is complete and testing can begin. If the system 
cannot identify the drive type or if the summary is not 
satisfactory to the operator, a series of questions and answers 
will allow the operator to enter the drive characteristics. 
However, it is strongly recommended that the operator determine 
why the system cannot identify the drive type before continuing. 
Check RPDT and RPSN registers (using CTL X command). See para- 
graph 1.8. 


The system automatically defaults to the upper five cyl- 
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inders of each unit. It tells the operator this in a message 
before inviting him to enter a command string. 


1.3 NORMAL COMMANDS 


Once the initialization dialogue is completed, the system is 
ready to begin testing. The operator may specify which tests are 
to be run, in which sequence and how many times. The operator may 
specify what action is to be taken when an error occurs, what 
information is to be reported in case of error, and when an error 
summary is to be given. The operator does this by means of the 
command language. This is made up of commands which tell the 
system what to do. Most of the commands tell the system which 
test or tests to run. some control the sequence of tests and some 
control the execution of the tests and the error reporting. 


A command consists of a mnemonic and two parameters. A cat~ 
riage return terminates the command entry. For example: 


>> AW BL 

! Vind What to do in case of error 
! ! (P=Pause, L=Loop, C=Continue 

i] i] 

ro) wt How many times to run the test 
t 

! Which test 


This command means: Run the address verify test 3 times. If 
there is an error, loop on the error until told to stop. Notice 
that commas are used to separate the mnemonic and the parameters. 


The operator does not need to enter the parameters if he wishes 
to use the default values. Thus: 


>> AV 


Means: Run the address verify test once, continue on error. 
This is equivalent to entering: 


b> AV, 1,C.. 


The operator may enter only one of the parameters and take the 
default value for the other. For example: 


>> AV,P 
is equivalent to: 


>> AV, 1,P 
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* Another example: 
>> AV, 12 
is equivalent to: 
>> AV, 12,C 
1.3.1 Primitive Commands: 


Many of the commands are primitive commands. That is, they re- 
fer to a single test or operation. These commands take the 
following form: 


MNEMONIC. N. (ERROR SPECIFIER) 
! ! i P = Pause on error 
' L = Loop on error 


Cc Ignore error (default) 


N 


i 
z 
2 


! 
i] 
! 
' of repetitions 
i 


O = Indefinite loop 
1 = Default 
99 = Highest value 


! 
i] 
i] 
! 
! 
! 
! 
! Two~letter name of test 


Primitive commands may be strung together in any order as many 
as desired. For example: 


>> AV,2,€ 
>> BB, 3,P 
>> CI.4 
>> CR 

>> CS 

>> / 


The slash (/) is the command to begin executing the command 
string. It also indicates the end of the command string. When 
the system has finished executing the command string, it is ready 
to accept a new string. 


In the above examples, the commands execute from first to last 
and then the execution ends. It is also possible to loop back on 
the string a specified number of times. This is done with two 
additional commands: 


>> LUP.N Loop to LPT N times 
>> LPT Loop back to here 


Qa 
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After running AV twice, it will run BB three times, MW four 
times, then repeat this six times before running CR and CS. 


1.3.2 Macro Commands: 


The macro command is intended to test a group of similar hard- 
ware components. Each macro command in the command string 
automatically calls a sequence of primitive commands. Each 
primitive command is run once unless told to loop on error. The 
macro commands take the following form: 


. MNEMONIC, N. (ERROR SPECIFIER) 
! : ! P = Pause on error 
: L. = Loop on error. 


' i 

! ‘ C = Ignore error (default) 
i] f 

! ! N = No. of repetitions 

! ! QO = Indefinite 
3 1 = Default 

! 99 = Maximum 

t 

i 


Two-letter name of macro 


ee ee 


Period indicates macro 


Example: 
>> .RG,3,C 
This means, run the set of register tests 3-times. Continue on 
error. It is exactly equivalent to the following string of 


primitive commands: 


>> LPT 
>> EK, 1, 
>> EM, 1, 
>> LUP,3 


The operator may string together several macros, may use loop 
commands, may mix in primitve commands as he chases. 
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Example: 


>> .BC,3,C 
o> LPT 

>> .DR,2 
>> .FILP 
>> LUP, 4 
>> MW 

>> / 


Macro commands are for convenience only. The same operation 
may be performed with the appropriate string of primitive com- 
mands. 


1.3.3 Global Commands: 


Global commands are intended to diagnose an entire hardware 
module. Each global command automatically callds a sequence of 
macro commands, each of which in turn calls a sequence of 
primitive commands. The global commands take the following form: 


“4MNEMONIC, N. (ERROR SPECIFIER) 
! t ! ! P = Pause on error 


i= Loop on error 
C = Ignore error (default) 


N = No. of repetitions 

O = Indefinite loop 
1 = Default 

99 = Maximum 


i 
i 
: 
! 
! 
! 
! 
: 
: 
! 


Two-letter name of global 


% indicates global 


Example: 
>> Z£DD,90,C 


Means, run the drive diagnostic, repeating indefinitely, con- 
tinue in case of error. This is exactly equivalent to: 


>> LPT 

>> . IN. 1,C 
>> .PS,1,C 
>> .DX,1,.C 


>> LUP,O 


This in turn, 


>> LPT 

>> ST. 1,€ 
>> SC,1,C 
>> §5,.1,C 
>> LS, 1,C 
>> OS,1,C 
>> RS, 1,C 
>> WD, 1,C 
>> LUP,O 
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is exactly equivalent to: 


The operator may intermix global, macro and primitve commands, 
using the loop commands as desired. The global command is for 


convenience only. 


The same result may be achieved by the 


equivalent string of macro commands or primitive commands. 


1.3.4 Utility Commands 


ES 


FM 


NP 


PN 


RD 


RE 


Print an error summary. 

Format the disc between the upper and lower 
limits using ‘'177777 data pattern, then check 
headers. 

Loop back to this point in the command string. 


Loop back to LPT N times, then go on. 


Means end of command = string. It is also the 
signal to begin executing the command string. 


Means to repeat the last command = string. 
Eliminates the need to re-enter it. 


Get the next data pattern from the table of 8 
patterns and use it as the current data pattern. 


Print the pass number. May be placed anywhere in 
the command string but is most logically placed 
at the end of a loop. 


Read the surface of the disc between the upper 
and lower limits. 


Clear the error summary and the log of words 
written and read. 


RL 


RP 


TD 
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Load a register. It allows the user to load the 
front panel switches into any desired CPA 
register and displays the result. For this 
command only, the error specifier means: 

L. = Go into a tight scope loop. 
P = Keep asking for a new CPA address. 
C = Load one register, then go to next test. 


Example (where 125252 is loaded into the 
switches): 


>> ENTER CMD 

>> RL: P 

>> / 

“-RL (REGISTER LOAD) 
>> ADDRESS (’176700)? = 176702 
= /125252 

>> ADDRESS ('176702)? 


In this example, the switches (125252) were 
loaded into location 176702 and the contents was 
read as 125252. The system then asked for the 


next address. If the user enters an odd number 
for the address, the system will round it down to 
the next lower even number. If the user enters 


the address of a non-existent memory location, 
the system will first trap: and then re-start the 
diagnostic at the beginning of the initial-—- 
ization. 


Another example: 


>> ENTER CMDS 

2> RLLL 

>> / 

--RL (REGISTER LOAD) 

>> ADDRESS ('174700)?7 = 176702 
>> LOOP ING--— 


In this example, the system is in a tight scope 
loop, loading the address 176702 with the 
contents of the front panel switches over and 
over again. The operator may change the data 
pattern at any time by changing the switches. He 
may use the CTL C dynamic command to stop the 
looping,» or he may use the CTL E dynamic command 
to change the error specifier. 


Get a random number and use it as the current 
data pattern. 


Print the date and time. 
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WH Write headers in the domain between the upper and 
lower limits using the current data pattern for 
data. 

ZR Perform the zig-zag read test. This is the same 
as the read portion of the oscillating track (OT) 
test. 


1.4 DYNAMIC COMMANDS 


Dynamic commands may be entered at any time. Any opera 
tion will be suspended until the dynamic command is com— 
pleted. Another dynamic command may be given before the 
present one is completed. The present one will be ab- 
orted at that instant, and the new command will be exe- 
cuted. When the operation returns to the normal command 
level, the current line of input/output will be reviewed 
up to the point where the dynamic command interrupted. 


Lines of output at the dynamic command level are prece- 
ded by double asterisk (##). For example: 


##% (CTL P) DATA PATTERNS 
CUR (/125252)7 = 


CTL A (CURRENT ADDRESS) 


This command prints the current disc address in the 
format: 


UNIT-CYLINDER-HEAD-SECTOR 


If the dynamic command is executed during or after a 
standard emulation test, it shows the address given in 
the CPA registers. If executed during or after an ex- 
tended emulation test, it shows the address in the cur- 
rent address software registers. 


CTL B (BOOTSTRAP) 


This command transfers control to the bootstrap program 
which allows the user to load software from the speci- 
fied device. The system will print: 


BOOT UNIT: - 


The operator may then enter the unit from which he wish- 
es to boot. If the user is in doubt as to what to en- 
ter, he may enter "?" and instructions will be given. 


In addition, the operator may also give a command which 
will write the diagnostic onto a mag tape. This i85 use- 
ful in cases where the user has entered patches to the 
diagnostic and wishes to save the updated version. 
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If the user wishes to return to the diagnostic, he may 
do so by hitting CTL I. 


CTL C (CLEAR COMMAND STRING) 


This command immediately terminates the execution of the 
command string and requests a new command string from 
the user. 


This command is essential for ending an infinite loop in 
the command string, or for terminating the unwanted re—- 
mainder of a command string. 


This command does not destroy the command string, and 
the user may re-start an existing command string by en- 
tering the \ (backslash) command. 


CTL E (ERROR SPECIFIER) 


This command allows the user to change the error speci- 
fier for the test currently being run. The command 
prints: 


## (CTL E) ERR SPEC (L)? = 


The letter in parenthesis indicates the current error 
specifier. If no letter is entered, the current speci- 
fier is retained. The operator may enter one of the 
following letters: 


L = Loop on error 
P = Pause on error 
C = Continue on error (ignore it) 


This will then become the current specifier until the 
next test or until the next loop of the same test. 


CTL F CERROR FORMAT) 
This command allows the user to specify what information 


he wants reported in case of error. Each piece of in- 
formation is identified by a two-letter mnemonic: 


BA, = RPBA EA, = Address-#Errors R2, = RPER2 
BE, = Bell EM, = Test’s error message R23, = RPERS 
cc, = RPCC GB, = Good/Bad S1, = RPCS1 
DA, = RPDA LA, = Logical address S2, = RPCS2 
pc, = RPDC PA. = Physical address Wc, = RPWC 
DS, = RPDS PC, = Program counter ref. 
DT. = Date Ri, = RPERI 

O = None of the above 

1 = All of the above 
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The command first reports the current format. For 
example: 


#% (CTL F) FORMAT = BE, DT. PC, LA, PA: WC, DS, DA, 
*## NEW FORMAT = 


The user then enters the desired mnemonics all on a sin- 


gle line, each one separated from the next by a comma. 
Gee section 1.6 for a full description of the error re- 
port. 


CTL G (READ HEADER }) 


This command allows the user to read and display any 


header. The user enters UN-CY-HD-SC (Unit. Cylinder, 
Head, Sector). The contents of the header specified are 
displayed. If a read error occurs, this fact is noted, 


but the data is still displayed. 


The command will continue asking for new addresses to 
read. When the user is finished, striking <RET> will 
return to the normal command level. 


CTL I CINITIALIZE) 


This command allows the user to re-initialize the sys- 
tem. He will go through the same initialization dia- 
logue as when he first started the diagnostic. 


CTL K (ERROR LIMIT, RETRY LIMIT) 


This command allows the user to define how many errors a 
drive will be allowed to make before being dropped from 
testing. The default value of zero indicates infinite 
errors allowed. Once a drive is dropped, that fact will 
be indicated by a message to the console. Also, a nota- 
tion will be made in the error summary. If all the 
drives are dropped, testing will be aborted. Clearing 
the error summary will allow drives to be re-instated. 


This command also allows the operator to set how many 
retries will be attempted before a hard error is logged. 


CTL N (ERROR SUMMARY): 


The user is given the choice to clear the error summary 
after printing or to allow it to accumulate. This will 
not. however, clear the summary of words written and 
read. 


ate 
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This command prints an error summary in five categories 


for each unit being tested. In each of these categor- 
ies, the first number is hard errors, the second is soft 
errors. 


Following this is a summary of the number of words writ- 
ten and read by each unit being tested. Since this can 
be avery large number, it is given in scientific nota~- 


tion. 

## (CTL N) ERR SUM 

>> CLR AFTER PRINTING (N)? 

ADDR VER DATA VER ECC ERROR CRC ERROR MISsc 
ERROR 
UNIT 0 3/75 120/200 0/0 0/0 5/0 


UNIT O WDS WRITTEN = 2. 56 E@2. READ = 2.56 E2 
CTL O (ECIB TABLE) 


If the previous operation has used extended emulation, 
this command prints the ECIB table associated with it. 


If the previous operation has used standard emulation, 
the command prints the current ECIB table as well as the 
three previous ECIB tables. This is printed in four 
columns, with the current table in the left-most column. 
For description of the ECIB table, see section 1. 7. 


CTL P (DATA PATTERN) 


This command displays the current data pattern and al- 
lows the user to change it. For example: 


## (CTL P) DATA PATTERNS 
CUR (/125252) 


The program expects an octal number. Following this, 
the pattern table is displayed item by item, allowing 
the user to change it. If the user does not want to 


change the table, he can strike the <ESC> key, or CTL Z 
CTL @ (TITLE SUPPRESS) 


This command allows the user to allow or suppress the 
printing of titles. 
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CTL R (RESUME) 


This command allows the user to resume operation under 
any of the following conditions: 


1. When a test has paused on error. 
2. When a test is suspended by the CTL S command. 


CTL § (SUSPEND) 


This command suspends all testing until the CTL R com- 
mand is given. Other dynamic commands may be executed 
during this suspension, but upon their completion, the 
testing will remain suspended. However, the CTL C com- 
mand will cancel the suspension. 


CTL U (DISC ADDRESS) 


This command allows the user to know the disc address 
upper and lower limits. The user may enter a new value 
or may retain the old one by pressing <RETURND> without 
entering a value. The program expects positive decimal 
integers whose value does not exceed the limits estab- 
lished at initialization. Example: 


(CTL Ud) 
## UPPER LIM (2-410-18-21) 
## LOWER LIM (0-0-0-0) 


The first number is unit number, the second is cylinder, 


the third is head, and the fourth is sector. If a new 
address is to be entered, all four numbers must be 
given. 


It is not advisable to change the limits while a test is 
running. Better to abort the test with CTL C. change 
the address limits, then use \ (backslash) to re-execute 
the command string. 


CTL W (REVIEW COMMAND STRING) 


If this command is executed while the command string is 
still being built, it will list all commands entered be- 


fore the last carriage return. Tf executed while a com- 
mand is executing, it will list all the commands in the 
string. In addition, an arrow will point to the test 
currently running, and a number beside the arrow will 
indicate how many iterations are left. For example: 

$s, 1,¢C 

LS,9,L <--5 

0S. 5,P 


/ 
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In addition, if a loop is being executed, an additional 
arrow at the LUP command will indicate how many itera- 
tions are left. Example: 


LPT 

SS, 1,.C 
LS.9%L <--5 
LUP,5S <--a 
LPT 

WP, 1,C 

CR; 3b 

LUP, & 


If the user has built the command string from macro 
(group of tests) or global (complete diagnostics) com- 
mands, the command interpreter will expand these to the 
primitive commands (tests). The review of the command 
string will show the primitive tests called by the 
macros or globals. For example: 


>> ENTER NEW CMDS 
2> .PS.L 
>> SC.C 


## (CTL W) CMD SUMMARY 
LPT 
SS, 1,L 
LS. ib 
os, 1,L 
RS, 1, 
LUP, 1 
Sc. 1,C€ 
/ 
2? 


The macro command .PS has been expanded into its compon— 
ent tests. 


CTL X (CPA REGISTERS) 


This command prints the contents of the CPA registers 
for each unit specified, from the lower to the upper 
limit. See section 1.8 for a full description of the 
CPA registers. 
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1.5 TEST SUMMARIES: 


1.5.1 


tek tun tt eat 


Hit he nk t tk tte te tn aba ae 


Summary of Primitive Tests: 


Address Verify 

Cre Error Test 
Cylinder Switch Test 
Data Verify Test 

ECC Error Test 

Echo Test 

Emulation Test 

Print Error Summary 
Format the Disc 
Format Test 

Header Test 

Head Switch Test 

CPU Interrupt Test 
Start of Loop 

Long Seek Test 

Loop Command 

MPU Interrupt Test 
Maximum Word Transfer 
Next Data Pattern 
Oscillating Seek Test 
Oscillating Track Test 
Print Pass Number 
Half Read Test 

Read Surface 

Reset Error Summary 
Register Load 

Next Random Data Pat. 
Random Seek Test 
Random Track W/R Test 
Sector Counter Test 
Sequential Seek Test 
Unit Status Test 
Single Word Xfr Test 
Print the Date 

Half Write CPU Test 
Half Wr/Rd Drive Test 
Write Headers 

Zig-zag read test 


GLOBAL 


“SD 
“SD 

“SD 

“SD 

“SD 

%CD 

%CD 
(Utility) 
(Utility) 
“8D 

%SD 

78D 

%CD 
(Utility) 
“DD 
(Utility) 
%CD 
%SD 
(Utility) 
7DD 

%DD 
(Utility) 
%~CD 
(Utiility) 
(Utility) 
(Utility) 
(Utility) 
“DD 


(Utility) 
“CD 
%DD 
(Utility) 
(Utility) 
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1 


1.5.2 Macro and Global Definitions: 


4CD = Computer Interface Diagnostic 
.RG = Register Tests 
EK = Echo Test 
NP = Next Data Pattern 
EK 


EM = Emulation Test 
. CF = CPU/Formatter Tests 
IT = CPA Interrupt Test 
MI = MPU Interrupt Test 
.DC = CPU/DMA Tests 
WC Half Write CPU Test 
RC Half Read CPU Test 


“4DD = Drive Diagnostic 
_. IN = Interface Tests 
ST = Unit Status Tests 
SC = Sector Counter Test 
.PS = Positioner Tests 
SS = Sequential Seek Test 
LS = Long Seek Test 
OS = Oscillating Seek Test 
RS = Random Seek Test 
.DX = Drive/DMA Tests 
WD = Half Read/Write Drive Test 


4SD = System Diagnostic 

.FI = Fault Injection Tests 
Bad Block Error Test 
CRC Error Test 
Ecc Error Test 
Address Verify Test 
Data Verify Test 
.BC = Boundary Condition Tests 


we 
w 
tt 


m 
a 
| i 


SW = Single Word Transfer Test 
MW = Maximum Word Transfer Test 
HS = Head Switch Test 

HD = Header Test 


Cylinder Switch 
.DR = Data Reliability Tests 
FT Format Test 
OT Oscillating Track Test 
RT Random Track Read/Write Test 
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1.6 ERROR REPORT: 
The error report consists of three parts: 


1. The contents of various registers as requested by 
the user. 


2. An analysis of the error bits contained in the 
error registers. 


3. An error message from the test itself. This 
includes an error number which is a reference to 
the Error Dictionary to which the operator may 
refer for a fuller analysis of the error. 


Since standard emulation tests use different registers 
than the extended emulation test do, the error report 
will look different for these two types of tests. The 
full error report for a standard emulation test will ap- 
pear as follows: 


M/D/Y -~ H:™:S PC = Program Counter RPER1 = Err Reg #1 
RPER2 = Err Reg #2 RPERS = Err Reg #3 ee RPCS1 = Ctl & Stat #1 
RPCS2 = Ctl & Stat #2 RPDS = Drive Status RPDA = Hd/Sect Addr 
RPDC = Desired Cyl RPCC = Current Cyl RPBA = Bus Addr 
RPWC = Word Count GD-BAD = Exp ’d-Rec‘d EA = Addr—-#Errors 
>> CPA REG STATUS: DISC ADDR = UN-CY-HD-SC 
(Analysis of error bits in cpa registers) 
Ha (Message from test) 
For a full description of the contents of the CPA regis~ 
ters, see section 1.8. 
The full error report for extended emulation tests will 
appear as follows: 
M/D/Y - H:M:S LOG ADR = Un/Cy/Hd/Sc PHYS ADR = U/C/H/S 
PC = Program Counter GD-BAD = Exp’d —- Rec’d EA = Addr-#Errors 


>> ECIB TABLE STATUS: 
(Analysis of error bits in ECIB table 
't (Message from test) 


If the user wishes to examine the ECIB table following 
an extended emulation test, he may use the CTL O dynamic 
command. For a full description of the contents of the 
ECIB table, see section 1.7. 
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1.7 ECIB TABLE: 
ECOS1 - OPERATION STATUS 1 


Octal Hexadecimal 

“900200 H-O0080 Any error 

“000100 H-0040 Deferred (not implemented) 
“000040 H-0020 Unit fault 

7000020 H-OO10 End of header timeout 
‘000010 H-0008 End of sector timeout 
“000004 H-0004 Data buffer timeout 
‘000002 H-0002 Parity error high 

‘o00001 H-O001 Parity error low 


EcCOS2 — OPERATION STATUS 2 


Octal Hexadecimal 

°000200 H-OO80 Hardware/firmware protect 
“000100 H-0040 Software protect 

“000040 H-0020 Address verify error 

‘000020 H-0010 Data verify error 

‘000010 H-0008 CRC error 

‘000004 H~-0004 ECC error 

‘000002 H-0002 ECC correction 

‘000001 H-0001 Retry cor. (not implemented) 


ECOS3 ~ OPERATION STATUS 3 


Qctal Hexadecimal 

‘000200 H-OO80 Pack overrun 

‘000100 H-0040 Bad block 

‘000040 H-0020 Last sector on pack 
7000020 H-0O010 Unit select fault 
7000010 H-OO008 Seek complete timeout 
‘000004 H-0004 Unit access error 
‘000002 H-0002 


‘900001 


H-0001 


Illegal command implementation 


CPA error 
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ECUS1 - PRIMARY DRIVE STATUS 


Octal Hexadecimal 

‘000200 H-0080 Attention 
‘000100 H-0040 Dual Port busy 
“000040 H-0020 Seek error 
7000020 H-0010 Unit selected 
“900010 H-0008 Write protected 
‘000004 H-0004 Fault 

“000002 H-0002 On cylinder 
“000001 H-O9001 Ready 


ECUS2 - MODEL BYTE OR SECTOR COUNT 
ECPORT - PORT NUMBER ON WHICH DRIVE WAS FOUND (0-3) 
ECCPA — COMPUTER PORT ADAPTER (CPA) NUMBER (0-3) 


ECFC - FUNCTION CODE 


Octal Hexadecimal 

“900000 H-0000 Clear controller 

‘900001 H-0001 Sense model status, put in ECUS2. 

7000002 H-0002 Sense sector count, put in ECUS2. 

‘000003 H-O003 Sense diagnostic status, put in 
ECUS2. 

#000004 H-0004 Sense fault status, put in ECOS1, 
EcOSs2, ECOSS3. . 

‘000005 H-0005 Firmware reserve. 

“000006 H-0006 Firmware reserve. 

‘000007 H-0007 Set firmware write protect. 

‘000010 H-0008 Clear firmware write protect. 

“000011 H-0009 Clear drive attention. 

‘000012 H-O00A Initiate recalibrate. 

‘000013  H-OOCB Initiate seek. 

‘000014 H-OOOC Write data. 

‘000015 H-OO00OD Read data. 

7000016 H-OOOE Read verify data. 

‘000017 H-OQOOF Write header. 

7000020 H-0010 Read header. 

‘900021 H-OO11 Read verify header. 

‘000022 H-0012 Write header & data. 

‘000023 H-0013 Read header & data. 

7000024 H-0014 Read verify header & data. 


ECLUC — PHYSICAL DRIVE NUMBER 
ECLCYH - LOGICAL CYLINDER ADDRESS (MS byte) 
ECLCYL —- LOGICAL CYLINDER ADDRESS ‘(L5 byte) 


ECLHED - LOGICAL HEAD ADDRESS 


ECLSEC 


ECPCYH 


ECPCYL 


ECPSEC 
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LOGICAL SECTOR ADDRESS 
PHYSICAL CYLINDER ADDRESS (MS byte) 
PHYSICAL CYLINDER ADDRESS (LS byte?) 


PHYSICAL. SECTOR ADDRESS 


ECFCM —- FUNCTION CODE MODIFIER 


Octal 


“9000200 
“000100 
‘000040 
“000020 
‘000010 
“000004 


Hexadecimal 


H-0O080 - Half operation 

H-O040 - Cpu side (if half operation) 
H-0020 - Include ECC/CRC in transfer 
H-OO10 -— ECC correction inhibit 
H-0008 —- Address compare inhibit 
H-0004 -— CRC error inhibit 


ECMSB - MAP STATUS BYTE 


Octal 
‘000200 
7000100 
7000040 


ECWCH 


ECWCL. 


ECSSO 


ECRPT 


ECRTY 


Hexadecimal 


H-O080 ~— New head 
H-0040 -—- New cylinder 
H-0020 - Last sector on pack 


WORD COUNT MS BYTE (2’s complement) 

WORD COUNT LS BYTE (2’s complement) 

STARTING STROBE OFFSET (not implemented) 
REPEAT COUNT STROBE/OFFSET (not implemented) 


TOTAL RETRY COUNT (not implemented) 


ECFLAG — FLAG BYTE 


Octal 


‘000200 
‘000100 


Hexadecimal 


H-OO8O - Write protected flag 
H-0040 ~- Bad sector flag 


ECUSER —- USER BYTE 


1.6 CPA REGISTERS: 


“100000 


‘040000 


*020000 
“004000 
‘002000 
“001000 
“000400 
‘000200 
“000100 
“000074 
‘000072 
‘000070 
‘000064 
‘000062 
7000060 
‘000054 
‘000050 
‘000030 
‘000022 
“000016 
‘000014 
‘000012 
‘000010 
‘000006 
*000004 
‘000002 
‘000001 
“000000 


°X174XX 


*XOO4XX 
XXXX27 
i 


“X¥XXXOO 
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7176702 -— RPWC 
‘176704 — RPBA 


“176706 - RPDA 


‘176700 - RPCS1 (Control & Status 1 Register): 


condition: Transfer error, or 


or 1/0 bus parity error. 


Special 
attention, 
or write check 


Transfer error: data late, 


error, or parity error, or non-existent 
drive, or non-existent memory, or program 
error, or missed transfer, or mass data 


bus, or drive error during transfer. 

Bus parity error (not used). 

Drive available (not used). 

Port select (not used). 

Unibus extension bit. 

Unibus extension bit. 

Ready. 

Interrupt enable. 

Read micro-control (extended emulation). 
Read header & data. 

Read data. 

Write micro-control (extended emulation). 
Write header & data. 

Write data. 

Jump micro-control (extended emulation). 
Write check data. 

Search command. 

Pack acknowledge. 

Return to centerline. 

Offset command. 

Release (dual port operation). 

Drive clear. 

Recalibrate. 

Seek. 

Unload (standby). 

60 bit. 

No operation. 


(Word count register) 

(Unibus address register) 

(Desired sector/head address register) 
Groaned eae padres’ #37 


Desired Head Address #1 
Desired Sector Address #27 
1 


Desired Sector Address #0 
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‘176710 - RPCS2 (Control & Status 2 register) 


“100000 -— Data late (not used). 
040000 - Write check error. 
‘020000 - Parity error (not used). 
7010000 — Non-existent drive. 
7004000 —- Non-existent memory. 
‘002000 —- Program error. 
‘001000 - Missed transfer. 
‘000400 — Mass data bus parity error (not used). 
7000200 —- Output ready 
"000100 - Input ready (not used). 
“000040 - Controller clear. 
‘000020 - Parity test (not used). 
000010 —- Inhibit bus increment. 
’000007 —- Select drive #7 

1 t 


1000000 - Select drive #0 
176712 ~ RPDS (Drive Status Register) 


7100000 ~- Attention active. 

7040000 - Error in RPER1, RPER2, or RPERS. 
‘020000 - Positioning in progress (not used). 
7010000 — Medium on Line. 

‘004000 - Write lock. 

"002000 -— Last sector transferred. 

7001000 - Programmable (not used). 

‘000400 — Drive present (not used). 

‘000200 —- Drive ready. 

‘000100 -— Volume valid. 

‘000001 — RMO3: Offset mode. RPO4: (not used). 


176714 - RPERi (Error Register #1) 


“100000 —- Data check, ECC error. 

‘040000 - Unsafe. 

“020000 - Operation incomplete (not used). 
7010000 —- Drive timing error (not used). 
7004000 —- Write lock error. 

002000 ~- Invalid address error. 

001000 —- Address overflow error. 

"000400 — Header CRC error. 

7000200 ~—- Header compare error. 

000100 - ECC hard error. 

‘000040 — Write clock failed (not used). 
‘000020 - Format error. 

‘000010 —- Parity error. 

7000004 - Register mod refused (not used). 
‘000002 - Illegal register (not used). 
‘000001 —- Illegal function. 
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‘176716 —- RPAS 


“000200 - 
‘000100 - 
“900040 - 
“000020 - 
“000010 - 
“000004 - 
‘000002 - 
‘900001 - 


°176720 RPLA 


“176722 RPDB 


‘176724 RPMR 


176726 - RPDT 


“020000 - 
7004000 - 
‘900020 —- 
7000021 —- 
‘000022 - 
‘000024 - 
‘000027 - 


‘176730 ~- RPSN 


(Attention Summary Register) 


Drive 
Drive 
Drive 
Drive 
Drive 
Brive 
Drive 
Drive 


Attention. 
Attention. 
Attention. 
Attention. 
Attention. 
Attention. 
Attention. 
Attention. 


— (Not emulated) 


- (Not emulated) 


(Data Buffer Register) 


- (Drive Type Register? 


Moving head disc type. 
Dual controller option available. 


RPO4 
RPOS 
RPO& 
RMO3 
RMOS 


(Serial Number Register) 


Used to indicate further drive information: 


If RPO4/RPOS/RPOG 


“100400 
‘140400 
101400 
“141400 


Hou on Rk 


Mapped 9762 
Direct 9762 
Mapped 97646 
Direct 9766 


If RMOS, bit 15 
If RMOS, bit 15 


“000400 
“001400 
‘002200 
“002000 
“002600 
°002400 
“003200 
7003000 
’003400 
7004000 
"004400 
“005000 
7005400 
°006000 
‘006400 
‘007000 


tu bd db tb bab kt at tb 


1 
1) 


9762 

9766 

9448-32 Fixed 
9446-32 Removable 
9446-64 Fixed 
9448-64 Removable 
9448-96 Fixed 
9448-96 Removable 
675 MB (W/O Fx Hd? 
675 MB (With Fx Hd) 
9730-80 .(W/O Fx Hd) 
9730-B80F (With Fx Hd) 
160 MB (W/O Fx Hd) 
160 MB (With Fx Hd) 
Mapped 140 MB 
Mapped 475 MB 
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176732 - RPOF (Offset Register) 


7100000 - Sign change (not used). 
‘010000 ~- Format bit (not used). 
‘004000 - Error correction code inhibit. 
‘002000 - Header compare inhibit. 


RPO4:. RMO3:_ 
‘000260 - Offset -—1200 micro-in. ‘900200 —- Offset 
towards 
spindle. 


‘000240 - Offset -800 micro-inches 
‘000220 - Offset -400 micro-inches 
‘000060 —- Offset +1200 micro-inches 
#000040 - Offset +800 micro-inches 
"9000020 - Offset +400 micro-inches 
‘000000 - Return to track centerline. 


‘176734 - RPDC (Desired Cylinder Register) 


°176736 - RPCC (Current Cylinder Register) 


RPO4: RMO3: 
Current Cylinder Not used 


176740 - RPER2 (Error Register #2) 


RPO4: RMO3: 
100000 - AC unsafe. Not used. 
‘020000 - Unsafe, R/W phase lock 

out of sync. 
‘010000 - 30 volts unsafe. 


1176742 - RPERS (Error Register #3) 


“100000 - Off cylinder (not used). 

“040000 - Seek incomplete. 

‘000100 - Low 5 volt DC (RPO4 only). 

“000040 - Low AC (RPO4 only?. 

‘000010 —- Head retract has occurred (RPO4 only). 
“000002 ~- Velocity unsafe (not used). 

‘000001 - Pack speed unsafe (not used). 


°176744 - RPEC1 (Not emulated) 
176746 - RPEC2 (Not emulated) 
‘176750 — RMBA (Bus Address Extension Register) 


PDP 11/770 only 
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176752 - RMSC3 (Control & Status #3) 


PDP 11/70 only 


“100000 — Address parity error. ; 
7040000 - Data parity error odd word. 
7020000 ~— Data parity error even word. 


7902000 ~ Last memory xfer was a double. word 
operation. 
19000100 - Interrupt enable 


2.0 


1 


(ZDD> 


(ST) 
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DRIVE DIAGNOSTIC: 


The 
ler 
The 
the 
are 


%DD diagnostic tests those portions of the control— 
which are most closely associated with the drive. 
tests make minimal usage of the CPA registers and 
emulation firmware. All instrunctions and status 
handled via the extended emulation. 


STATUS TEST: 


Execution time: 4 seconds. 
Prerequisites: None. 
Type of emulation: Extended. 


Tests the status bits in ECUS1 as follows: 


i: 


Performs a Recal and checks that the "On Cylind- 
er" bit has set in a reasonable time. If not, it 
flags an error and returns to the monitor, If 
"On Cylinder" sets, it checks the status bits in 
ECUS1 which should be as shown: 


ECUS1 
Bit 7 = O/1 Attention 
Bit 6=0 Dual port busy 
Bit 5 = 0 Seek error 
Bit 4 = 1 Unit selected 
Bit 3 = O/1 Write protected 
Bit 2 = 0 Fault 
Bit i= 1 On cylinder 
Bit O=1 Ready 


If not» the test flags an error and returns to 
the monitor. 


Seeks to cylinder #1 and checks that the "On Cyl- 
inder" bit has set in a reasonable time. T# not, 
it flags an error and returns to the manitor, 


2.2 


(SC) 
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a. Seeks to an impossible cylinder (177777), and 
waits for either "Seek Error” or "On Cylinder" 
bit to set in a reasonable time. If not set, it 
flags an error and returns to the monitor. If 


set, it checks the status bits in ECUS1 which 
should be as shown: 


ECUS1 
Bit 7 = O/1 Attention 
Bit 6 = 0 Dual port busy 
Bit 5=1 Seek error 
Bit 4 = 1 Unit selected 
Bit 3 = O/1 Write protected 
Bit 2 = 0 Fault 
Bit i=i On cylinder 
Bit O= 1 Ready 
4, Does a long seek. Checks that the "On cylinder" 


bit is clear while the drive is seeking, and that 
it sets at the end of the seek. 


APPLICABLE ERROR REPORT OPTIONS: 


PA: Contains drive address 
LA: 
EM: Gives error message from test. 


SECTOR COUNTER TEST: 


Execution time: 10 seconds. 
Prerequisites: None. 
Type of emulation: Extended. 


The test requests the sector count and places it ina 
buffer. It continues to do this as fast as the firmware 
can supply the count until the buffer is full. It then 
analyzes the numbers in the buffer and determines that 
every integer between O and the maximum sector count 


given at initialization is present. If any integers are 
missing, the test flags and error and returns to the 
monitor. 


APPLICABLE ERROR REPORT OPTIONS: 
GB: Good/Bad. The first number is the expected 
sector count, the second number is that re- 


ceived (octal). 


LA: Address shows which unit is failing. 
PA: 


EM: Gives error message from test. 


2.3 


2.4 


2. 


- 
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(SS) SEQUENTIAL SEEK TEST: 


(LS) 


(0S) 


Execution time: 2 minutes (80 megabyte). 

Prerequisites: Upper cylinder limit must be greater 
than the lower limit. 

Type of emulation: Extended 


Performs sequential seeks from the lower to upper cyl- 
inder address. One pass through the test will sequent-— 
ially ascend and descend through all the cylinder addr- 
esses once. After each seek, the test checks status and 
reports any error. 


APPLICABLE ERROR REPORT OPTIONS: 


PA: Contains the seek address which caused the 
error. 
LA: 


EM: Gives error message from test. 


LONG SEEK TEST: 


Execution time: 1 second. 
Prerequisites: Upper cyl Limit must be greater than 
lower. 


Type of emulation: Extended. 
This test seeks from the lower limit cylinder address to 
the upper limit cylinder address and back again. It 
checks status after each seek. If the status showns an 
error, it flags an error and returns to the monitor. 
APPLICABLE ERROR REPORT OPTIONS: 

PA: Contains the seek address which caused the 

error. 
LA: 


EM: Gives error message from test. 


OSCILLATING SEEK TEST: 


Execution time: 5S minutes, 20 seconds (80 Megabyte). 
Prerequisites: Upper cyl limit must be greater than 
lower. 


Type of emulation: Extended. 


Seeks from the lowest cylinder to the lowest+1 and back 
again. Then it seeks from the iowest to the lowest+2 
and back again. It continues seeking from the lowest to 
successively higher addresses until the upper limit is 
reached. Then it successively reduces the upper address 
until it equals lowest+1 again. 


2.6 


2.7 


(RS) 


(WD) 
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APPLICABLE ERROR REPORT OPTIONS: 
PA: Contains the seek address which caused the 
error. 
LA: 


EM: Gives error message from the test. 


RANDOM SEEK TEST: 
Execution time: 1 minute, 30 seconds (80 Megabyte). 
Prerequisites: Upper cylinder limit must be greater 
than the lower limit. 

Type of emulation: Extended 
Seeks from one random cylinder address to another within 
the domain bounded by the upper and lower limits of the 
cylinder address as set by the dynamic command CTL U. 
It continues until all the cylinders within that domain 
have been addressed. It checks status after each seek 
and reports the first error. It tallies successive er- 
rors in the error summary. 
APPLICABLE ERROR REPORT OPTIONS: 

PA: Contains the seek addresses which caused the 

error. 

LA: 

EM: Gives error message from the test. 
HALF READ/WRITE TEST: 
Execution time: 2 seconds. 


Prerequisites: None. 
Type of emulation: Extended. 


Fills all the RAM buffer with an incrementing data pat- 
tern, one word at a time using the WMC command in exten- 
ded emulation. Does a half write header and data to the 
drive. Clears the RAM. Does a half read header and 
data from the drive. Checks data in the RAM one word at 
a time. 
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The RAM data buffer is loaded as follows: 


Loc. 


1000 
1001 
1002 
1003 
1004 
1005 
1006 
1007 
1008 
1009 
100A 
i) 
1107 
1108 
1109 
! 
1206 
1207 


(Hex) Contents (Hex) 


10 ! 
00 ! 
00 '—~--Header (for disc 
00 : address 0-0-0-0) 


'—-—Data 


o 
: OTN: 


APPLICABLE ERROR REPORT OPTIONS: 


GB: 


EA: 


EM: 


This gives the expected data and the actual 
data. Since the data is stored in RAM in 
8-bit bytes, the right hand side of the number 
will be the data byte, the left hand side of 
the number will always be zero. 


This gives the address in RAM (octal) where 
the first error occurred (the one reported in 
GB). The number to the right of this is the 
total number of errors that occurred during 
the transfer. , 


Gives error message from the test. 


3.0 


3. 


1 
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(ZCD) COMPUTER INTERFACE DIAGNOSTIC 


(EK) 


TEST PHILOSOPHY 


The %CD diagnostic tests those portions of the computer 
interface which communicate the least with the disc, 
i.e. this diagnostic deals only with computer inter- 
face-controller communications where possible. 


These tests include: 
.RG Register Tests 


EK Register Echo Tests 
EM Register Emulation Tests 


.CF CPU/Formatter Tests 


IT CPU Interrupt Test 
MI Microprocessor Interrupt Test 


. DC CPU DMA Tests 


RC RAM Buffer Test 
WC Half Write CPU Test 


REGISTER ECHO TEST: 


Execution time: 1 second. 

Prerequisites: Must have version 1.3 (RMO3) or 2.1 
(RPO4) of the firmware, and CPA 
board 7400-6031 date code A913 or 
A907. 

Type of emulation: Standard. 


Tests the ability of each computer interface register to 
accept and hold data. This is accomplished by target- 
ting each register for test. The target register is 
loaded with the user specified pattern (see CTL PP), ex- 
cept control and read only bits. All other computer in- 
terface registers are loaded with the complement of the 
user specified pattern. This allows detection of ad- 
dressing or continuous loading errors. Then the con- 
tents of the target register is recalled and compared to 
the user specified pattern. If the comparison is not 
equal, an error report is displayed. 


APPLICABLE ERROR REPORT OPTIONS: 
EA: The first number shows the target register ad- 


dress: the second number shows the number of 
errors (always 1). 


3.2. ¢EM) 
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GB: First number is the data pattern which was 
loaded into the target register and which was 
expected to be read back; the second number 
is the number actually read back from the tar—- 
get register. 


EM: Gives an error message from the test. 


Note: To insure a complete test, (EK) should be run 
four times in sequence using the following four data 
patterns: 


‘177777 
“9000000 
125252 
‘052525 


PON 


This is done automatically when running the “CD global 
command. 


REGISTER EMULATION TEST: 


Execution time: 1 second. 

Prerequisites: Must have version 1.3 (RMOS3) or 2.1 
(RPO4) of the firmware. 

Type of emulation: Standard. 


Tests those bits of the computer interface registers 
which could not, for one reason or another, be tested by 
the (EK) test. 


‘The bits are (in order tested): 


MOL; DRY. or VV stuck at zero. 

ATA stuck at one. 

SC, TRE stuck at one. 

RDY stuck at zero. 

stuck at zero after controller function. 
ATA stuck at zero. 
ERR stuck at one 
RDY stuck at one during Write. 
GO stuck at zero. 

10. GO stuck at one after Write. 

11. PGE stuck at one. 

12. PGE stuck at zero. 

13. IR» CLR stuck at zero. 

14. Sc, TRE stuck at zero. 

15. ERR stuck at zero. 


SoS ee Se N= 
a 
oO 
< 


APPLICABLE ERROR REPORT OPTIONS: 


Same as for the EK test 
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3.3 (IT) CPU INTERRUPT TEST: 


Execution time: 1 second. 
Prerequisites: None. 
Type of emulation: Standard. 


Requests a computer interface interrupt at a priority 
level of 7 and tests that an interrupt does not occur at 
level & and “7. Tests that an interrupt does occur at 
level 5%, and that it does not occur after it has been 
serviced. Also detects if an interrupt occurs at any 
other unexpected vector. 


APPLICABLE ERROR REPORT OPTIONS: 
EM: Error message from test. 
3.4 (MI) MICROPROCESSOR INTERRUPT TEST: 


Execution time: 1 second. 
Prerequisites: None. 
Type of emulation: Standard. 


Loads unit #7 into RPCS2, loads 40 (controller clear) 
into RPSC2, and waits for the IR bit to be set by the 
microprocessor. If the IR bit is not set after a small 
wait, an error is reported. 


APPLICABLE ERROR REPORT OPTIONS: 
EM: Error message from the test. 
3.5 (RC) RAM DATA BUFFER TEST: 


Execution time: 4 seconds. 
Prerequisites: None. 
Type of emulation: Extended. 


Tests the two extended emulation functions: write micro- 
code and read microcode. Consequently, it tests the 
1024 words of microprocessor RAM. The test is imple- 
mented by writing and reading microcontrol one byte at a 
time of the user specified pattern over to and back from 
the RAM area. The data sent is compared to the data re- 
ceived, and errors are reported. 


APPLICABLE ERROR REPORT OPTIONS: 
EA: First number is the RAM address of the first 


error: the second number is the total number 
of errors found. 


3.6 
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GB: First mumber is the expected data pattern to 
be found in the RAM location shown in EA a- 
bove; the second number is the data actually 


read from the RAM Location. 


EM: Gives an error message from the test. 


(WC) HALF WRITE CPU TEST: 


Execution time: 2 seconds. 
Prerequisites: None. 
Type of emulation: Extended. 


Tests the ability of the CPU interface-controller to 
write DMA to the microprocessor RAM area. This is veri- 
fied by reading the RAM back to the CPU by using read 
microcontrol commands. The data sent is compared to the 
data received and errors are reported. 


APPLICABLE ERROR REPORT OPTIONS: 


GB: The first number is the pattern written: the 
second number is the pattern read back. 


EA: The first number is the RAM address of the 
first error detected: the second number is 
the total number of RAM errors detected. 


EM: Error message from the test 
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(“¥SD) SYSTEM DIAGNOSTIC 


(BB). 


(CR) 


The %SD diagnostic tests all the parts of the disc sys- 
tem which have previously been tested individually, or 
which have not yet been tested. In the Data Reliability 
tests, the standard emulation firmware is tested for the 
first time, and all elements of the system are brought 
into play. 


Note: In the test descriptions below, the execution time 
and number of bits transferred is given for an 80 mega— 
byte mapped drive, and the diagnostic operating in 28K 


of memory. Larger capacity drives will require longer 
execution times and transfer more bits of data in many 
of the tests. Smaller memory size will increase the 


execution time in many of the tests. 


BAD BLOCK ERROR TEST: 


Execution time: 3 seconds. 
Prerequisites: None 

Type of emulation: Extended 

Data pattern: *Q00000 and ’177777. 


Tests the operation of the bad block bit in the header. 
Writes a sector with all zero data and the bad block bit 
set in the header. Attempts to write all ones into that 
sector. Checks that the bad block error bit is set. 
Attempts to read data from that sector. Checks that the 
bad block error bit sets. Removes the bad block bit 
from the header, reads the header and verifies that the 
data is still all zeros. If it is all ones, then the 
system wrote in spite of the bad block bit in the 
header. 


APPLICABLE ERROR REPORT OPTIONS: 


EM: Error message from test will explain contents. 


CRC ERROR TEST: 


Execution time: 3 seconds. 
Prerequisite: None. 

Type of emulation: Extended. 
Data pattern: 4177777. 


Checks the validity of the CRC check word in the header. 
First, it writes a header, then reads the header and CRC 


word. It then compares this CRC word with a software. 
generated CRC word and verifies that the two are the 
same. Finally, it writes a header with an erroneous CRC 


word and verifies that the CRC error bit is set when the 
header is read back. 
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APPLICABLE ERROR REPORT OPTIONS: 


EM: Error message from the test will explain 
contents. 


ECC ERROR TEST: 


Execution time: 7 seconds. 
Prerequisite: None. 

Type of emulation: Extended. 

Data pattern: Current pattern. 


Checks the validity of the ECC error detection and cor- 
rection system. The test writes a sector of data and 
reads it back, checking status and data. Compares the 
ECC remainder with a software generated ECC remainder 


and verifies that they are the same. It then creates it 
consecutive errors in the data and writes it and the ECC 
remainder. Upon reading the data again, it verifies 


that the data error was corrected, and that a correct— 
able ECC error bit was posted. This time it creates 12 
consecutive errors in the data and writes it and the ECC 
remainder. Upon reading the data back again, it veri- 
fies that the hard ECC error bit was posted. 


APPLICABLE ERROR REPORT OPTIONS: 


EM: The error message from the test will explain 
the contents. 


ADDRESS VERIFY TEST: 


Execution time: 14 seconds (approximately). 
Bits transferred: 3.28 x 10##4 bits. 
Prerequisite: None. 

Type of emulation: Extended. 

Data pattern: ‘000000 and ’177777. 


Checks the ability of the system to detect a discrepancy 
between the address written in the header, and the act- 
val physical address of the sector being accessed. It 
does this by writing an incorrect address in a header 
and then attempting to read the sector, verifying that 
the address verify error bit sets. It performs the test 
four times, setting errors in each of the four elements 
of the address in the header, namely: Head, Sector, 
Cylinder hi, and Cylinder lo. 


APPLICABLE ERROR REPORT OPTIONS: 


EM: The error message from the test will explain 
the contents. 


4.35 
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DATA VERIFY TEST: 


Execution time: 1 second. 

Bits transferred: 4096 bits. 
Prerequisite: None. 

Type of emulation: Standard. 

Data pattern: Current pattern. 


Verifies the operation of the write check function. 
Writes 32 sectors of data, then performs a write check 
operation, and checks status. It alters the data in CPU 
memory and performs a write check operation again. veri- 
fying that the write check error bit sets. 


APPLICABLE ERROR REPORT OPTIONS: 


EM: The error message from the test will explain 
the contents. 


SINGLE WORD TRANSFER TEST: 


Execution time: 1 second. 

Bits transferred: 16 bits. 

Prerequisite: None. 

Type of emulation: Standard. 

Data pattern: °125252. 

Tests the system’s ability to transfer less than a full 
sector of data, in this case a single word. It fills 
the entire data buffer with ‘125252, but writes only a 
single word. It then clears the buffer, reads back a 


single word, and verifies that only that single word got 
read back into the buffer. 


APPLICABLE ERROR REPORT OPTIONS: 
EM: The error message from the test gilt: sipiain: 
MAXIMUM WORD TRANSFER TEST: 
Execution time: 1 second. 
Gize of transfer: Depending on the memory size and the 


length of the command string: will 
transfer 11-12 sectors worth. 


Prerequisite: None. 
Type of emulation: Standard. 
Data pattern: Current pattern. 


Tests the system’s ability to handle large multi-~sector 
data transfers. It sizes the available memory space in 
the CPU and makes the largest data transfer possible. 
Since the memory space is variable depending on the size 
of the command string and the amount of memory avail-—- 


4.8 


4.9 


CHS) 


CHD) 
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able, the test prints out the size of the data transfer 
for the operator’s information. The test formats and 
individually writes data in enough sectors to cover the 
transfer. It then treads all the data ina single 
multi-sector read. 
APPLICABLE ERROR REPORT OPTIONS: 


EM: The error message from the test will explain. 


HEAD SWITCH TEST: 


Execution time: 4 seconds. 

Bits transferred: 2.95 x 10%#5 bits. 
Prerequisite: None. 

Type of emulation: Standard. ; 
Data pattern: 125252, ‘000000, '177777. 


Tests the system’s ability to perform multi-sector 
transfers across head boundaries. First, it individ- 
vally writes a sector on either side of the boundary, 
then does a 2—-sector read of the two sectors. Then it 
does a @=-sector write across a head boundary and per- 
forms two single sector reads of the same sectors. It 
repeats this over all the head boundaries. 


APPLICABLE ERROR REPORT OPTIONS: 
EM: The error message from the test will explain. 


HEADER TEST: 


Execution time: 14 seconds. 

Bits transferred: 3.28 x 10##4 bits. 
Prerequisite: None 

Type of emulation: Extended. 

Data pattern: *000000 and ‘177777. 


Checks the ability of the system to detect a discrepancy 
between the address written in the header, and the act-— 
val physical address of the sector being accessed. It 
does this by writing an incorrect address in a header 
and then attempting to read the sector, checking that 
the address verify bit sets. It performs the test four 
times, setting errors in each of the four elements of 
the address in the header, namely: Head, Sector, Cyl- 
inder hi, and Cylinder lo. 


APPLICABLE ERROR REPORT OPTIONS: 


EM: The error message from the test will explain. 
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4.10 (CS) CYLINDER SWITCH TEST: 


Execution time: i second. 

Bits transferred: 655 x 10##4 bits. 
Prerequisite: None. 

Type of emulation: Standard. 

Data pattern: 425252, ‘000000. ‘177777. 


Tests the system’s ability to perform multi-sector 
transfers across cylinder boundaries. First, it indiv- 
iduvally writes a sector on either side of the boundary, 
then does a 2-sector read of the two sectors. Then it 
does a 2-sector write across a cylinder boundary and 
performs two single sector reads of the same sectors. 
It repeats this over four different cylinder boundaries. 


APPLICABLE ERROR REPORT OPTIONS: 
EM: The error message from the test will explain. 


4.11 (FT) FORMAT TEST: 


Execution time: 5 minutes, 15 seconds (80 megabyte). 
Bits transferred: 5.44 x 10#*8 bits written. 

5.39 x 10##8 bits read. 
Prerequisites: None. 
Type of emulation: Standard. 
Data pattern: Current pattern. 


Formats the disc between the limits set by the operator, 
using the largest multi~sector transfers that memory 
size will allow. Reads the headers in a mass transfer, 


checking status. The table below shows the header in- 

formation: ‘ 
RPO4: RMO3: 

ng nL 
HEADER HEADER 

Wd i *100000+Cylinder Wd 1 7150000+tcylinder 

Wd 2 Head-Sector Wd 2 Head~-sector 

Wd 3 “000000 

Wd 4° “000000 

et ce a a 
DATA DATA 

Wd 1 ‘o00001 Wd i ‘000001 

Wd 2 ‘000000 Wd 2 7000000 

Wd 3 ‘000000 Wd 3 “000060 

Wd 4 ‘000000 Wd 4 “000000 

Wd 3 Current Pattern Wd 5 Current Pattern 

1 


Wd 256 Current Pattern Wd 254 Current Pattern 
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APPLICABLE ERROR REPORT OPTIONS: 

EM: The error message from the test will explain. 
Note: When formatting a pack for system use, use the FM 
command (instead of this FT test). This will automatic— 


ally write the correct data for proper handling of bad 
blocks. 


OSCILLATING TRACK TEST: 


Execution time: 7 minutes, 5 seconds (80 Megabyte). 
Bits transferred: 1.69 x 10%#7 bits. 
Prerequisite: The disc must first be formatted 


(use the FT test, the WH command or 
the FM command). 

Type of emulation: Standard. 

Data pattern: Current pattern. 


This is a data reliability test wherein data is written 
on ascending cylinder addresses, and read from oscillat- 
ing cylinder addresses. Data is read one sector at a 
time, always from sector O of any head or cylinder. 
First from the lowest cylinder, lowest head, then from 
the highest cylinder, highest head. After each read, 
the lower head address is incremented and the upper head 
address is decremented. The test reads back and forth 
between the upper and lower addresses until the two meet 
in the middle. 


APPLICABLE ERROR REPORT OPTIONS: 


EM: The error message from the test will explain. 


RANDOM TRACK TEST: 


Execution time: 10 minutes (80 Megabyte). 
Bits transferred: 2.70 x 10##8 bits. 
Prerequisite: The disc must first be formatted 


{use the FT test, the WH command or 
the FM command). 

Type of emulation: Standard. 

Data pattern: Current pattern. 


Writes a track at a time on random cylinder addresses 
and treads a track at a time from random cylinder addr- 
esses. 


APPLICABLE ERROR REPORT OPTIONS: 


EM: The error message from the test will explain. 
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WRITE HEADER UTILITY: 


Execution time: 3 minutes, 14 seconds (80 Megabyte). 
Bits transferred: 5.44 x 10#*68 bits Write 
O bits Read. 
Prerequisite: None. 
Type of emulation: Standard. 
Data Pattern: Current pattern. 


This command allows the operator to write headers and 
data. He can write header for a single sector, or for 
any contiguous group of sectors, or for all the sectors 
on a disc. The command sizes the available memory space 
to perform the largest multi-sector write possible. It 
writes header and data in all sectors between the lower 
and upper address limits. 


ZIG-ZAG READ UTILITY: 


This is identical to the read portion of the OT test 
(Paragraph 4. 12) 
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5.0 DICTIONARY OF ERRORS 


i" 


N 2 w F YON 


10. 


11. 


12. 


13. 


14. 


15. 


16. 


17. 


Timed out trying to initialize the controller. 
Timed out trying a random write operation. 

Timed out trying a random read operation. 

Timed out trying an incrementing write operation. 
Timed out trying to read. 

Error status occurred after a read operation. 


Error status after read was OK, but the data read back did 
not compare to that written. 


Timed out trying to write two single headers spanning a 
cylinder boundary. 


Error status occurred after a two-sector read across a 
cylinder boundary. 


Timed out trying to do a two-sector read across a cylinder 
boundary. 


Data was written across a cylinder boundary in two single 
sector write operations. Data was read in a single two- 
sector tread operation. The data read back does not match 
that written. ; 


Error status occurred while doing a two-sector read across 
a cylinder boundary. 


Timed out trying to do a two-sector write across a cylin- 
der boundary. 


Error status occurred while doing a two-sector write ac- 
Toss a cylinder boundary. 


Timed out while trying the first i-sector read of data 
written in a single two-sector write. 


Data was written in a single two-sector write operation. 
Data was tread in two single-sector read operations. The 
data read from the first sector does not match that writ- 
ten. 


Data was written in a single two-sector write operation. 
Data was tread in two single-sector read operations. Error 
status occurred during the first single-sector read. 


18. 


19. 


20. 


21. 


ee. 


23. 


24. 


295. 


26. 


27. 


29. 


- 30. 


StL. 


Q 
f 
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Data was written in a single two-sector write operation. 
Data was read in two single-sector read operations. con- 
troller timed out while trying the second single-sector 


read. 


Data was written in a single two-sector write operation. 
Data was read in two single-sector read operations. The 
data from the second single-sector read does not match 


that written. 


Data was written in a single two-sector write operation. 
Data was Tead in two single-sector read operations. Error 
status occurred during the second single-sector read. 


Timed out trying to write two single headers and data 
spanning a head boundary. 


Error status during two single-sector writes across a head 
boundary. 


Timed out trying a two-sector read across a head boundary. 


Wrote data in two single-sector writes across a head boun- 
dary. Read data in a single two-sector read. The data 
read does not match that written. 


Error status occurred during a two-sector read across a 
head boundary. 


Timed out trying a two-sector write across a head boun- 
dary. 


Error status occurred during a two-sector write across a 
head boundary. 


Did a two-sector write across a head boundary. Timed out 
trying to do the first single-sector read. 


Did a two-sector write across a head boundary. Read data 
in two single-sector reads. The data in the first single- 
sector read does not match that written. 


Did a two-sector write across a head boundary. Did two 
single-sector treads. Error status occurred during the 
first single-sector read. 


Did a two-sector write across a head boundary. Read data 
in two single-sector reads. Timed out reading the second 
sector. 


Did a two~-sector write across a head boundary. Read data 
in two single-sector reads. The data read from the second 
sector does not match that written. 


33. 


34. 


39. 


36. 


37. 


38. 


39. 


40. 


41. 


42. 


43. 


44, 


45. 


46. 


47. 


48. 


49. 


9o. 


31. 


oe. 
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Did a two-sector write across a head boundary. Read data 


in two single-sector reads. Error status occurred during 
the second read. 


Timed out trying to write header and data. 


Error status occurred while writing a single header and 
data. 


Timed out trying a maximum—-sized multi-sector read. 


Data read in the maximum-sized multi-sector read does not 
match that written in multiple single-sector writes. 


Error status occurred during a maximum-sized multi-sector 
read. 


Timed out trying to write a single word. 
Error status occurred while writing a single word. 
Timed out trying to read a single word. 


Wrote a single word, then read it back. The word read 
back does not match that written. 


Error status occurred while reading a single word. 


Did a single-word transfer. The single word was OK, but 
the fill characters were not all zeros. 


Timed out tring to put the header address into the RAM 
buffer. 


Timed out trying to load zeros into the ram buffer. 


Timed out trying to write header & data using extended 
emulation. 


Error status occurred in ECIB table after writing header 
and data. 


Timed out trying to put an incorrect header address into 
the RAM buffer. 


Timed out trying to write an incorrect header using ex- 
tended emulation. 


Timed out trying to read the sector with the incorrect 
header, using extended emulation. 


The "ADDRESS Verify" error bit did not set in ECOS2 after 
reading an incorrect header. 


33. 
94. 
35. 
96. 


37. 


98. 
59. 


40. 
61. 


62. 


63. 
64. 
65. 
66. 
67. 


68. 


69. 


70 


71. 
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Timed out trying to load all 1’s into the RAM buffer. 


Timed out tring to write data into a sector with an incor 
rect header. 


The “Address Verify" error bit did not set in EcOS2 after 
trying to write into a sector with an incorrect header. 


Timed out trying to load the correct header into the RAM 
buffer. 


Timed out tring to write the correct header using extended 
emulation. 


Error status in ECIB table after writing correct header. 
Timed out trying to load RAM with data. 


Timed out trying to read the sector with the corrected 
header. 


Error status occurred in the ECIB table after reading the 
sector with the corrected header. 


Unexpected data was read into the RAM buffer from the 
disc. The data in the sector was originally all zeros. 
The test attempted to write 177777 when the sector had an 
incorrect header. If the RAM contains 177777, this indi- 
cates that the controller wrote into the sector in spite 
of the incorrect header. If the RAM contains 125252, this 
means no read took place after the header had been cor- 


rected. The RAM buffer should contain all zeros at this 


point. 

Timed out while attempting to write headers. 

Showed error status after writing headers. 

Timed out while attempting to write data. 

Error status occurred after writing data. 

Timed out attempting to do a write check of good data. 

The "Write Check" error bit in RPCS2 set when no write 
check error was intenoced. Possibly caus’ 4 by bad surface 
on the disc. ; ; 


The “Write Check" error bit in RPCS2 did not set when 
there was a write check error. 


Timed out trying to load header into RAM buffer. 


Timed out trying to load data inte the RA" buffer. 


72. 


73. 
74. 
75. 


76. 


77. 
78. 


79. 
80. 
81. 
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Timed out trying to write header and data using extended 
emulation. 


Error status in ECIB table after writing header and data. 
Timed out trying to fill RAM buffer with zeros. 
Timed out trying to read data and the ECC polynomial. 


Error status in the ECIB table after reading the data and 
the ECC polynomial. 


Timed out trying to get data from the RAM buffer. 
The hardware and software ECC polynomials do not compare. 


Timed out trying to read or write into or from the RAM 
buffer. 


Timed out trying to load the correctable error into the 
RAM buffer. 


Timed out trying to write data with correctable errors (11 
errors). 


Error status in ECIB table after writing data with cor- 
rectable errors. 


Timed out trying to fill RAM buffer with zeras. 
Timed out trying to read the corrected data. 


The "Soft ECC Error” bit did not set after a soft ECC er- 
Tor occurred. 


The correctable errors in the data did not get corrected, 
even though ECOS2 indicated a soft ECC error status. 


Timed out trying to read data from the RAM buffer. 


Timed out trying to load the RAM buffer with data contain- 
ing an uncorrectable ECC error. 


Timed out trying to read data from RAM buffer. 


Timed out trying to load data with an uncorrectable error 
in it into the RAM. 


Timed out trying to write a sector with an uncorrectable 
error in it. 


Error status in the ECIB table after writing a sector with 
an uncorrectable error in it. 


93. 


114. 


115. 


121. 


122. 
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124. 
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Timed out trying to read the sector with an uncorrectable 
error in it. 


The MECC Error" bit in ECOS2 did not set after reading 
data with an uncorrectable error in it. 


Error status occurred while writing header and data. 
Timed out trying to load header into RAM buffer. 
Timed out trying to store data into RAM buffer. 


Timed ovt trying to load header and data into the RAM buf- 
fer in order to set the bad block flag in the header. 


Error status in the ECIB table after writing header and 
data to set the bad block flag in the header. 


Timed out trying to load data into RAM buffer. 


Timed out trying to write into a sector with the bad block 
flag set in the header. 


Did not get "Bad Block" status in ECOS3 when attempting to 
write into a bad block (extended emulation?. 


Timed out trying to read a sector with the bad block flag 
set in the header. 


Did not get "Bad Block" status in ECOS3 when attempting to 
read a bad block (extended emulation). 


Timed out trying to check data in RAM buffer. 
Timed out trying to load header into RAM buffer. 


Timed out trying to write the header with the bad block 
flag removed. 


Error status in ECIB table after writing header with the 
bad block flag cleared. 


Timed out trying to read a sector after the bad block flag 
has been cleared. 


The "Bad Block" bit in ECOS3 still sets after re-writing 
the header with the bad block flag cleared. 


Timed out trying to check data in RAM buffer. 
Was able to read the sector in spite of the bad block flag 


set in the header. The data in the sector was all zeros. 
The data in the RAM was ‘125252 before the read. The data 


125. 


126. 
127. 
128. 
129. 
130. 
131. 
132. 
133. 
134. 
135. 


136. 


137. 
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in the RAM should have remained unchanged. Interpretation 
of the error report: 


GD-BAD = ‘000252-’000000: Read sector with bad block 
flag set. 


Wrote into a sector with the bad block flag set. The test 
originally wrote zeros, then set the bad block flag. It 
then attempted to write ones in that sector. It removed 
the bad block flag by re-writing the header. Then, it 
filled the RAM with 125252 data, and read the sector back. 
If the RAM still contains 125252, then the read did not 
actually take place. If the RAM contains all ones, then 
the system wrote into the sector in spite of the bad block 


flag. Interpretation of the error summary: 
GD-BAD = ‘000000- ’000377 Data over written. 
GD-BAD = ‘000000- ‘000252 Bad read. 


Timed out trying to load header into RAM buffer. 

Timed aut trying to write header. 

Error status in ECIB table after writing header. 

Timed out trying to load data into RAM buffer. 

Timed out trying to read header and CRC word. 

Timed out trying to get header from RAM buffer. 

Timed out trying to get header from RAM buffer. 

Timed out trying to get CRC from RAM buffer. 

Timed out trying to get CRC from RAM buffer. 

Hardware and software CRC words do not match each other. 


Timed out trying to load an erroneous CRC word into the 
RAM buffer. 


Timed out trying to write a header with an erroneous CRC 
word. 


Timed out trying to read a header with an erroneous CRC 
word. 


The "CRC Error" bit in ECOS2 did not set after reading a 
header with an erroneous CRC word. 


Timed out trying to load the cylinder most significant 
byte of the header into the RAM buffer. 


141. 


142. 


143. 


144. 


201. 
202. 
203. 
204. 
205. 
206. 
207. 
208. 
209. 
210. 
211. 
212. 
213. 
214. 
215. 
216. 
217. 
218. 
219. 
220. 


221. 
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Timed out trying to load the cylinder least significant 
byte of the header into the RAM buffer. 


Timed out trying to load the head address of the header 
into the RAM buffer. 


Timed out trying to load the sector address of the header 
into the RAM buffer. 


Timed out trying to load the two key words of the header 
into the RAM buffer. 


Timed out trying to initialize the controller. 
An error was detected in register RPCS1. 

An error was detected in register RPWC. 

An error was detected in register RPBA. 

An error was detected in register RPDA. 

An error was detected in register RPERI. 


An error was detected in register RPAS. 


An error was detected in register RPLA. 


An error was detected in register RPDB. 
An error was detected in register RPMR. 
An error was detected in register RPDT. 
An error was detected in register RPSN. 
An error was detected in register RPOF. 
An error was detected in register RPDC. 
An error was detected in register RPCC. 
An error was detected in register RPER2. 
An error was detected in register RPER3. 
An error was detected in register RPEC1. 
An error was detected in register RPEC2. 
An error was detected in register RHBAE. 


An error was detected in register RPCS3. 
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"Medium On Line", "Data Ready". or "Volume Valid" bits in 

RPDS are stuck at zero. 

"Drive Ready" bit in RPDS stuck at zero. 

"Yolume Valid" bit in RPDS stuck at zero. 

"Attention Active" bit in RPCS1 stuck at one. 


"Special Attention” or “Transfer Error" bit in RPCS1 stuck 
at one. 


"Ready" bit in RPCS1 stuck at zero. 


"Ready" bit in RPCS1 stuck at zero. 


“Attention Active” bit in RPDS stuck at zero. 
"Error" bit in RPDS stuck at one. 

"Ready" bit in RPCS1 stuck at zero. 

"Go" bit in RPCS1 stuck at zero. 

"Go" bit in RPCS1 stuck at one. 

"Program Error" bit in RPCS2 stuck at one. 
"Program Error” bit in RPCS2 stuck at zero. 
Timed out trying to initialize controller. 
Timed out waiting for "Ready" bit in RPCS1. 


"Special Condition" or “Transfer Error” bit in RPCS1 stuck 
at zero. 


"Error" bit in RPDS stuck at zero. 


Unexpected interrupt occurred at priority levels greater 
than six. 


Unexpected interrupt occurred at priority levels greater 
than five. 


No interrupt received when expected at priority levels 
greater than three. 


Multiple interrupts occurring. 
Microprocessor did not respond to interrupt. 


Timed out trying to load the RAM buffer. 
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Half-write CPU failed. 
Timed out trying to fill the RAM buffer. 
RAM data buffer failure. 


Ready bit did not set after attempted write to an illegal 
cylinder. 


MPU did not respond to a recal command. 
"On Cylinder" bit did not set after recal command. 


Unexpected status after recal. Check ECUS!: “Dual Port 
Busy", "Seek Error”, “Fault” bits. 


Unexpected status after recal. Check ECUS1: "On Cylin- 
der", “Unit Select", and "Attention" bits. 


MPU did not respond to a seek command. 


"On Cylinder" or "Geek Error" bit did not set after a 
seek. 


MPU did not respond to recal command. 

"On Cylinder" bit did not set after recal. 

MPU did not respond to a seek command. 

MPU did not respond to an RMC command. 

"On Cylinder" bit did not clear during a long seek. 
MPU. does not respond to a WMC command. 


The highest sector count detected does not match that giv- 
en for this model. 


Unexpected status after a recal command. 
"On Cylinder" bit did not set after a recal. 
Unexpected status after a seek command. 
Unexpected status after a seek command. 
Unexpected status after a seek command. 
"On Cylinder" bit did not set after a seek. 


Unexpected status after a seek command to lowest cylinder. 
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Unexpected status after a seek command to highest cylin- 
der. 


Unexpected status after a seek command from highest to 
lowest cylinder. 


Unexpected status after a recal command. 

"On Cylinder" bit did not set after a seek. 

Unexpected status after a seek command to cylinder #1. 
Unexpected status after a seek command to cylinder #0. 


Unexpected status after a seek command to a higher cylin- 
der. 


Unexpected status after a recal command. 

"Qn Cylinder" bit did not set after a recal. 
Unexpected status after a seek to a random address. 
MPU did not respond to a WMC command. 

MPU did not respond to a half-write drive command. 
"Ready" bit in RPCS1 did not set after write. 

MPU did not respond to WMC command. 

MPU did not respond to half-read drive command. 
"Ready" bit in RPCS1 did not set after read. 


Data from half-read drive does not compare with that writ- 
ten. 
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